草庐IT

Flink系列Table API和SQL之:时间属性

全部标签

ruby-on-rails - 将日期与 rails3 中的日期时间 Created_at 进行比较

所以我正在尝试做这样的事情:today=Date.today-1todaysReport=Report.where(:created_at=>today).find_by_user_id(user.id)问题是created_at是一个日期时间,所以它找不到任何匹配项。有什么建议吗? 最佳答案 你可能想要这样的东西:yesterday=Time.now-1.dayuser=User.find(user_id)todaysReport=user.reports.where(["created_at>=?ANDcreated_at

ruby-on-rails - 在不使用 FormBuilder 的情况下访问 fields_for 中的嵌套模型属性

我有一个Rails表单,用于创建和编辑具有has_many关系的模型。我非常熟悉带有嵌套模型的典型表单,但我当前的问题需要使用典型的FormBuilder帮助程序访问呈现某些表单元素,并使用模型本身的数据访问其他HTML元素。例如,我的顶级表单有如下内容:'customer_image_show',:locals=>{:f=>images_form}%>然后,在部分形式中,我需要做类似的事情:...但也可以从customer_images模型访问属性(例如,customer_image记录的ID)。我觉得这应该非常简单,我只是缺少一些基本的东西。任何帮助表示赞赏。这是一个Rails2.

ruby-on-rails - 计算两个 Time 对象之间的时间差

假设我从我的用户模型中创建了两个时间对象:created=u.created_atupdated=u.updated_at如何计算两个时间对象之间的小时差?hours=created-updated我想将它包装在一个方法中并扩展Time类。我很难相信我需要扩展它,但我似乎无法找到一种本地方法来处理使用不同时间单位计算耗时。 最佳答案 这应该有效:hours=((created-updated)/1.hour).round相关问题:RailsTimedifferenceinhours 关于

ruby-on-rails - 在不更改系统时钟的情况下在 rspec 测试中设置系统时间

我正在努力让Rails3应用程序准备好使用时区。我的开发机器在美国东部时间,我托管的服务器在UTC。在我的rspec测试中有没有一种方法可以更改ruby​​使用的系统时区,这样我就可以使用相同的系统时区运行测试,而不必更改我计算机上的系统时钟?我研究过Delorean和Timecop,它们不是我要找的。我正在寻找类似的东西Time.system_time_zone="UTC"...然后Time.now将返回UTC时间,而不是我的系统时区设置的时间。 最佳答案 before{Time.stub(:now){Time.now.utc}}

ruby-on-rails - 如何清理 Rails 4 中的原始 SQL

在Rails3中,我可以使用sanitize_sql_array为那些偶尔需要原始SQL查询的时刻清理原始SQL。但这似乎已在Rails4中删除,或者没有删除太多,而是移至ActiveRecord::Sanitization。但是,我现在不知道如何调用sanitize_sql_array,那么在Rails4中清理原始SQL的最佳方法是什么?我想澄清一下,我在这里谈论的是完整的原始SQL查询,而不是使用Rail的模型。我知道这不是最佳实践,这正是我必须为这个特定查询做的事情,因为它不能用Rails漂亮的ActiveRecord接口(interface)表示(相信我,我已经试过了)。这是一

ruby-on-rails - Rails 5.2 Active Storage 添加自定义属性

我有一个带有附件的模型:classProject当我附加并保存图像时,我还想保存附加的自定义属性-display_order(整数)和附加图像。我想用它来对附加的图像进行排序,并按照我在此自定义属性中指定的顺序显示它们。我已经查看了#attach方法以及ActiveStorage::Blob模型的ActiveStorage源代码,但看起来没有内置方法来传递一些自定义元数据。我想知道,用ActiveStorage解决这个问题的惯用方法是什么?在过去,我通常只是将display_order属性添加到代表我的附件的ActiveRecord模型,然后简单地将它与.order(display_o

sql - Ruby 中的 pretty-print SQL

有没有一种简单的方法可以在(rails3)控制台中pretty-print随机SQL?类似于awesome_print的内容,甚至可能是PrettyPrint.它不需要理解所有可能的方言或非常高级。我真正想要的是更轻松地检查ActiveRecord生成的SQL。目前我只是将SQL复制到网上进行格式化,这显然是生产力killer。我真的很想query.to_sql.pretty_format_sql并查看更好的输出。谢谢。 最佳答案 试试这个:gitclonehttps://github.com/sonota/anbt-sql-for

sql - Arel中 "where exists"怎么办

如何在Arel中执行包含“whereexists”的查询?例如,在这样的查询中显示至少有一个订单的所有供应商:SELECT*FROMsuppliersWHEREEXISTS(SELECT*FROMordersWHEREsuppliers.supplier_id=orders.supplier_id);我在Arel文档中看到“存在”http://rubydoc.info/gems/arel/2.0.7/Arel/Nodes/Exists但我在使用它时遇到了问题。 最佳答案 给你:suppliers=Supplier.arel_tabl

ruby - 使用 YARD 记录模型属性

我正在使用YARD使用makrdown作为脚本解析器为我的Rails应用程序生成文档。大多数文档功能开箱即用。但是,我还想将模型属性记录为一个,记录模型上的可用属性列表和两个,以描述它们的语义。我无法在YARD中找到对此的任何特殊支持,我基本上只能在类注释中简单地列出属性。有没有办法记录动态生成的模型属性,以便它们像标准属性/方法一样出现在文档中?附言我已经使用annodate-modelsgem在类列表的顶部生成基本模式转储,但这并不是我真正想要的。 最佳答案 似乎YARD现在有自己的@!attribute(注意感叹号)标签用于此

ruby - 有没有办法查看 Sequel 表达式将生成的原始 SQL?

假设我有一个像这样的Sequel表达式:db.select(:id).from(:some_table).where(:foo=>5)有没有办法获取这将生成的SQL字符串(即"SELECTidFROMsome_tableWHEREfoo=5")?我注意到对上述表达式的结果调用inspect或to_s包括生成的SQL,但不确定如何直接访问它。以及不返回数据集的Sequel表达式如何,例如:db.from(:some_table).update(:foo=>5)是否可以在执行之前从中看到SQL? 最佳答案 你可以在数据集上调用sql:d